package it.unipd.dei.bd.icineasti.database;

import it.unipd.dei.bd.icineasti.resource.Fornitore;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;

/**
 * Restituisce il dettaglio del fornitore
 *
 * @author Mattia Coccato
 */
public class GetFornitoreDatabase {

	/**
	 * Interrogazione al database.
	 */
	private static final String STATEMENT = "SELECT nome, telefono, email, url FROM Fornitore WHERE piva = ?";
	
	/**
	 * Connessione al database
	 */
	private final Connection con;
	
	/**
	 * Risultati della ricerca
	 */
	private Fornitore fornitore;

	private final String piva;
	
	public GetFornitoreDatabase(Connection con, String piva) {
		this.con = con;
		this.piva = piva;
		fornitore = null;
	}

	public Fornitore getFornitore() throws SQLException {

		PreparedStatement pstmt = null;
		ResultSet rs = null;

		try {
			pstmt = con.prepareStatement(STATEMENT);

			pstmt.setString(1, piva);

			rs = pstmt.executeQuery();

			while (rs.next()) {
				fornitore = new Fornitore(piva, rs.getString("nome"), rs.getString("telefono"), rs.getString("email"), rs.getString("url"));
			}

		} finally {
			if (rs != null) {
				rs.close();
			}

			if (pstmt != null) {
				pstmt.close();
			}

			con.close();
		}

		return fornitore;
	}
}
